package com.genersoft.iot.vmp.vmanager.gb28181.playback;

import com.genersoft.iot.vmp.common.StreamInfo;
import com.genersoft.iot.vmp.gb28181.transmit.callback.DeferredResultHolder;
//import com.genersoft.iot.vmp.media.zlm.ZLMRESTfulUtils;
import com.genersoft.iot.vmp.service.IMediaServerService;
import com.genersoft.iot.vmp.storager.IRedisCatchStorage;
import com.genersoft.iot.vmp.service.IPlayService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.alibaba.fastjson.JSONObject;
import com.genersoft.iot.vmp.gb28181.bean.Device;
import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
import com.genersoft.iot.vmp.storager.IVideoManagerStorage;
import org.springframework.web.context.request.async.DeferredResult;

@Api(tags = "视频回放")
@CrossOrigin
@RestController
@RequestMapping("/api/playback")
public class PlaybackController {

	private final static Logger logger = LoggerFactory.getLogger(PlaybackController.class);

	@Autowired
	private SIPCommander cmder;

	@Autowired
	private IVideoManagerStorage storager;

	@Autowired
	private IRedisCatchStorage redisCatchStorage;

	// @Autowired
	// private ZLMRESTfulUtils zlmresTfulUtils;

	@Autowired
	private IPlayService playService;

	@Autowired
	private DeferredResultHolder resultHolder;

	@Autowired
	private IMediaServerService mediaServerService;

	@ApiOperation("开始视频回放")
	@ApiImplicitParams({
			@ApiImplicitParam(name = "deviceId", value = "设备ID", dataTypeClass = String.class),
			@ApiImplicitParam(name = "channelId", value = "通道ID", dataTypeClass = String.class),
			@ApiImplicitParam(name = "startTime", value = "开始时间", dataTypeClass = String.class),
			@ApiImplicitParam(name = "endTime", value = "结束时间", dataTypeClass = String.class),
	})
	@GetMapping("/start/{deviceId}/{channelId}")
	public DeferredResult<ResponseEntity<String>> play(@PathVariable String deviceId, @PathVariable String channelId,
													   String startTime,String endTime) {

		if (logger.isDebugEnabled()) {
			logger.debug(String.format("设备回放 API调用，deviceId：%s ，channelId：%s", deviceId, channelId));
		}

		DeferredResult<ResponseEntity<String>> result = playService.playBack(deviceId, channelId, startTime, endTime, null, wvpResult->{
			resultHolder.invokeResult(wvpResult.getData());
		});

		return result;
	}

	@ApiOperation("停止视频回放")
	@ApiImplicitParams({
			@ApiImplicitParam(name = "deviceId", value = "设备ID", dataTypeClass = String.class),
			@ApiImplicitParam(name = "channelId", value = "通道ID", dataTypeClass = String.class),
			@ApiImplicitParam(name = "stream", value = "流ID", dataTypeClass = String.class),
	})
	@GetMapping("/stop/{deviceId}/{channelId}/{stream}")
	public ResponseEntity<String> playStop(
			@PathVariable String deviceId,
			@PathVariable String channelId,
			@PathVariable String stream) {

		cmder.streamByeCmd(deviceId, channelId, stream, null);

		if (logger.isDebugEnabled()) {
			logger.debug(String.format("设备录像回放停止 API调用，deviceId/channelId：%s/%s", deviceId, channelId));
		}
		if (StringUtils.isEmpty(deviceId) || StringUtils.isEmpty(channelId) || StringUtils.isEmpty(stream)) {
			return new ResponseEntity<>(HttpStatus.BAD_REQUEST);
		}

		if (deviceId != null && channelId != null) {
			JSONObject json = new JSONObject();
			json.put("deviceId", deviceId);
			json.put("channelId", channelId);
			return new ResponseEntity<>(json.toString(), HttpStatus.OK);
		} else {
			logger.warn("设备录像回放停止API调用失败！");
			return new ResponseEntity<>(HttpStatus.INTERNAL_SERVER_ERROR);
		}
	}

	@ApiOperation("回放暂停")
	@ApiImplicitParams({
			@ApiImplicitParam(name = "streamId", value = "回放流ID", dataTypeClass = String.class),
	})
	@GetMapping("/pause/{streamId}")
	public ResponseEntity<String> playPause(@PathVariable String streamId) {
		logger.info("playPause: "+streamId);
		JSONObject json = new JSONObject();
		StreamInfo streamInfo = redisCatchStorage.queryPlayback(null, null, streamId, null);
		if (null == streamInfo) {
			json.put("msg", "streamId不存在");
			logger.warn("streamId不存在!");
			return new ResponseEntity<String>(json.toString(), HttpStatus.BAD_REQUEST);
		}
		Device device = storager.queryVideoDevice(streamInfo.getDeviceID());
		cmder.playPauseCmd(device, streamInfo);
		json.put("msg", "ok");
		return new ResponseEntity<String>(json.toString(), HttpStatus.OK);
	}

	@ApiOperation("回放恢复")
	@ApiImplicitParams({
			@ApiImplicitParam(name = "streamId", value = "回放流ID", dataTypeClass = String.class),
	})
	@GetMapping("/resume/{streamId}")
	public ResponseEntity<String> playResume(@PathVariable String streamId) {
		logger.info("playResume: "+streamId);
		JSONObject json = new JSONObject();
		StreamInfo streamInfo = redisCatchStorage.queryPlayback(null, null, streamId, null);
		if (null == streamInfo) {
			json.put("msg", "streamId不存在");
			logger.warn("streamId不存在!");
			return new ResponseEntity<String>(json.toString(), HttpStatus.BAD_REQUEST);
		}
		Device device = storager.queryVideoDevice(streamInfo.getDeviceID());
		cmder.playResumeCmd(device, streamInfo);
		json.put("msg", "ok");
		return new ResponseEntity<String>(json.toString(), HttpStatus.OK);
	}

	@ApiOperation("回放拖动播放")
	@ApiImplicitParams({
			@ApiImplicitParam(name = "streamId", value = "回放流ID", dataTypeClass = String.class),
			@ApiImplicitParam(name = "seekTime", value = "拖动偏移量，单位s", dataTypeClass = Long.class),
	})
	@GetMapping("/seek/{streamId}/{seekTime}")
	public ResponseEntity<String> playSeek(@PathVariable String streamId, @PathVariable long seekTime) {
		logger.info("playSeek: "+streamId+", "+seekTime);
		JSONObject json = new JSONObject();
		StreamInfo streamInfo = redisCatchStorage.queryPlayback(null, null, streamId, null);
		if (null == streamInfo) {
			json.put("msg", "streamId不存在");
			logger.warn("streamId不存在!");
			return new ResponseEntity<String>(json.toString(), HttpStatus.BAD_REQUEST);
		}
		Device device = storager.queryVideoDevice(streamInfo.getDeviceID());
		cmder.playSeekCmd(device, streamInfo, seekTime);
		json.put("msg", "ok");
		return new ResponseEntity<String>(json.toString(), HttpStatus.OK);
	}

	@ApiOperation("回放倍速播放")
	@ApiImplicitParams({
			@ApiImplicitParam(name = "streamId", value = "回放流ID", dataTypeClass = String.class),
			@ApiImplicitParam(name = "speed", value = "倍速0.25 0.5 1、2、4", dataTypeClass = Double.class),
	})
	@GetMapping("/speed/{streamId}/{speed}")
	public ResponseEntity<String> playSpeed(@PathVariable String streamId, @PathVariable Double speed) {
		logger.info("playSpeed: "+streamId+", "+speed);
		JSONObject json = new JSONObject();
		StreamInfo streamInfo = redisCatchStorage.queryPlayback(null, null, streamId, null);
		if (null == streamInfo) {
			json.put("msg", "streamId不存在");
			logger.warn("streamId不存在!");
			return new ResponseEntity<String>(json.toString(), HttpStatus.BAD_REQUEST);
		}
		if(speed != 0.25 && speed != 0.5 && speed != 1 && speed != 2.0 && speed != 4.0) {
			json.put("msg", "不支持的speed（0.25 0.5 1、2、4）");
			logger.warn("不支持的speed： " + speed);
			return new ResponseEntity<String>(json.toString(), HttpStatus.BAD_REQUEST);
		}
		Device device = storager.queryVideoDevice(streamInfo.getDeviceID());
		cmder.playSpeedCmd(device, streamInfo, speed);
		json.put("msg", "ok");
		return new ResponseEntity<String>(json.toString(), HttpStatus.OK);
	}

}
